import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

// 导入element-ui
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
// 引入全局样式
import '@/assets/global.less'
// 导入axios
import axios from 'axios'
// 添加默认请求网址
axios.defaults.baseURL = 'http://www.liulongbin.top:3008'

// 添加请求拦截器
axios.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  // 给my路径下的加头token
  if (config.url.startsWith('/my')) {
    config.headers.Authorization = store.state.token
  }
  return config
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error)
})

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  return response
}, function (error) {
  // 对响应错误做点什么
  if (error.response.state === 401) {
    store.commit('updateToken', '')
    router.push('/login')
  }
  return Promise.reject(error)
})
Vue.use(ElementUI)
Vue.config.productionTip = false
// 将axios挂到Vue原型上
Vue.prototype.$http = axios
new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')
